Page({
  data: {
    name: '',
    gender: 1,
    mobile: '',
    idcardFrontUrl: '',
    idcardBackUrl: ''
  },
  onLoad({ point, building, room }) {
    // 获取房屋参数，并存入 data
    this.setData({
      point,
      building,
      room
    })
  },
  // 验证业主姓名
  validName() {
    // 验证业主姓名（必须为汉字）
    const reg = /^[\u4e00-\u9fa5]{2,5}$/
    // 验证业主姓名
    const valid = reg.test(this.data.name.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写真实中文姓名!')
    // 返回验证结果
    return valid
  },
  // 验证手机号
  validMobile() {
    // 验证手机号
    const reg = /^1[3-8]\d{9}$/
    const valid = reg.test(this.data.mobile.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写正确的手机号码!')
    // 返回验证结果
    return valid
  },
  // 验证身份证照片
  validPicture() {
    // 图片地址不能为空
    const valid = !!this.data.idcardFrontUrl && !!this.data.idcardBackUrl
    // 验证结果提示
    if (!valid) wx.utils.toast('请上传身份证照片')
    return valid
  },
  // 上传身份证图片
  async uploadPicture(ev) {
    // ev.mark.type: 用户区分身份证正面还是反面
    console.log(ev.mark.type, '点击上传图片通过事件传递过来的参数');
    // 通过 wx.chooseMedia这个 API 用户可以打开相机拍照
    // 或从机册中选择图片
    await wx.chooseMedia({
      count: 1,
      mediaType: ['images'],
      // 默认是压缩模式
      sizeType: ['compressed'],
      success: (res) => {
        // 获取临时图片地址
        console.log(res.tempFiles[0].tempFilePath, '获取临时图片地址');
        // 调用接口上传图片
        wx.uploadFile({
          url: wx.http.baseURL + '/upload',
          // 临时图片地址
          filePath: res.tempFiles[0].tempFilePath,
          // 后端接收文件数据时用的名字
          name: 'file',
          header: {
            Authorization: getApp().token
          },
          success: (res) => {
            // 转换 json 数据
            const url = JSON.parse(res.data).data.url
            // 将图片地址存到 data 中，从而渲染到页面上
            // 对url进行判断
            if (ev.mark.type === 'idcardFrontUrl') {
              // 点击的是身份证正面
              this.setData({
                idcardFrontUrl: url
              })
            } else {
              // 点击的是身份证反面
              this.setData({
                idcardBackUrl: url
              })
            }
          }
        })
      }
    })
  },
  removePicture(ev) {
    // 移除图片的类型（身份证正面或反面）
    const type = ev.mark.type
    this.setData({
      [type]: ''
    })
  },
  // 点击提交审核
  async submitForm() {
    // wx.reLaunch({
    //   url: '/house_pkg/pages/list/index'
    // })
    // 1. 校验业主姓名
    if (!this.validName()) return
    // 2. 校验手机号
    if (!this.validMobile()) return
    // 3. 校验身份证
    if (!this.validPicture()) return

    // 删除小程序内置的数据
    delete this.data.__webviewId__

    // 提交我的房物页信息
    const { code } = await wx.http.post('/room', this.data)
    // console.log(res, '提交房屋信息返回的页面');
    if (code !== 10000) return wx.utils.toast()

    // 成功后跳转至房屋列表
    wx.navigateBack({
      delta: 4
    })
  }
})
